# **Solutions - Midterm Exam**

(October 13<sup>th</sup> @ 5:30 pm)

Presentation and clarity are very important! Show your procedure!

### PROBLEM 1 (20 PTS)

a) Complete the following table. The decimal numbers are unsigned: (6 pts.)

|   | Decimal | BCD          | Binary  | Reflective Gray Code |  |
|---|---------|--------------|---------|----------------------|--|
|   | 52      | 01010010     | 110100  | 101110               |  |
| Γ | 34      | 00110100     | 100010  | 110011               |  |
|   | 85      | 10000101     | 1010101 | 1111111              |  |
|   | 122     | 000100100010 | 1111010 | 1000111              |  |

b) Complete the following table. Use the fewest number of bits in each case: (12 pts.)

| REPRESENTATION |                        |                |                |  |
|----------------|------------------------|----------------|----------------|--|
| Decimal        | Sign-and-magnitude     | 1's complement | 2's complement |  |
| -63            | 1111111                | 1000000        | 1000001        |  |
| -26            | 111010                 | 100101         | 100110         |  |
| 0              | 00                     | 11111          | 0              |  |
| 110            | <mark>0</mark> 1101110 | 01101110       | 01101110       |  |
| -32            | 1100000                | 1011111        | 100000         |  |
| -16            | 110000                 | 101111         | 10000          |  |

c) Convert the following decimal numbers to their 2's complement representations. (2 pts)

| -19.6875                 | ✓ 16.3125              |
|--------------------------|------------------------|
| +19.6875 = 010011.1011   | +16.3125 = 010000.0101 |
| ⇒ -19.6875 = 101100.0101 |                        |

## PROBLEM 2 (15 PTS)

• Complete the timing diagram of the circuit shown below.  $y = y_3 y_2 y_1 y_0$ ,  $x = x_1 x_0$ ,  $s = s_1 s_0$ 



### PROBLEM 3 (18 PTS)

- a) Perform the following additions and subtractions of the following unsigned integers. Use the fewest number of bits *n* to represent both operators. Indicate every carry (or borrow) from  $c_0$  to  $c_n$  (or  $b_0$  to  $b_n$ ). For the addition, determine whether there is an overflow. For the subtraction, determine whether we need to keep borrowing from a higher byte. (6 pts)
  - $\begin{array}{c} \textbf{I} & \textbf{$
- b) Perform the following operations, where numbers are represented in 2's complement. Indicate every carry from  $c_0$  to  $c_n$ . For each case, use the fewest number of bits to represent the summands and the result so that overflow is avoided. (8 pts)
- c<sub>3</sub>=0 n = 7 bits  $c_{7=1}$  $c_{6=1}$  $c_{5=0}$  $c_{2=1}$  $c_{4=1}$  $c_{3=1}$  $c_{2=0}$  $c_{1=0}$  $c_{1=0}$  $c_2 = 0$  $c_1 = 1$  $C_7 \oplus C_6 = 1 - 63 = 1 0 0 0 0 1 +$ -26 = 1 1 0 0 1 1 0 +c<sub>7</sub>⊕c<sub>6</sub>=0 Overflow! -15 = 1 1 1 0 0 0 1  $45 = 0 \ 1 \ 0 \ 1 \ 1 \ 0 \ 1$ No Overflow  $19 = 0 \ 0 \ 1 \ 0 \ 0 \ 1 \ 1$ 0 1 1 0 0 1 0  $-26 + 45 = 19 \in [-2^{6}, 2^{6}-1] \rightarrow \text{no overflow}$  $-63 - 15 = -78 \notin [-2^6, 2^6 - 1] \rightarrow \text{overflow!}$ To avoid overflow: n = 8 bits (sign-extension)  $c_6=0$  $c_5=0$  $c_4=0$  $c_3=0$ c<sub>8</sub>⊕c<sub>7</sub>=0 No Overflow  $-63 = 1 \ 1 \ 0 \ 0 \ 0 \ 0 \ 1 \ +$ -15 = 1 1 1 1 0 0 0 11 0 1 1 0 0 1 0  $-63 - 15 = -78 \in [-2^7, 2^7 - 1] \rightarrow \text{no overflow}$
- c) Perform binary multiplication of the following numbers that are represented in 2's complement arithmetic with 4 bits. (4 pts)  $\checkmark$  -7 x 6.



#### PROBLEM 4 (10 PTS)

- The figure below depicts the entire memory space of a microprocessor. Each memory address occupies one byte. 1KB = 2<sup>10</sup> bytes, 1MB = 2<sup>20</sup> bytes, 1GB = 2<sup>30</sup> bytes
  - ✓ What is the size (in bytes, KB, or MB) of the memory space? What is the address bus size of the microprocessor?

Address space:  $0 \times 00000$  to  $0 \times FFFFF$ . To represent all these addresses, we require 20 bits. So, the address bus size of the microprocessor is 20 bits. The size of the memory space is then  $2^{20} = 1$  MB.

✓ If we have a memory chip of 128 KB, how many bits do we require to address those 128 KB of memory?

128 KB memory device: 128KB =  $2^{17}$  bytes. Thus, we require 17 bits to address the memory device.

✓ We want to connect the 128 KB memory chip to the microprocessor. For optimal implementation, we must place those 128 KB in an address range where every single address shares some MSBs. Provide a list of all the possible address ranges that the 128 KB memory chip can occupy. You can only use any of the non-occupied portions of the memory space as shown below.



#### PROBLEM 5 (10 PTS)

• Sketch the circuit that computes  $|A - B| \times 4$ , where *A*, *B* are 4-bit signed (2's complement) numbers. For example:  $A = 1010, B = 0111 \rightarrow |A - B| \times 4 = 13 \times 4 = 52$ . You can only use full adders and logic gates. Your circuit must avoid overflow.

 $A = a_3 a_2 a_1 a_0, B = b_3 b_2 b_1 b_0$ 

 $A, B \in [-8,7] \rightarrow A, B$  require 4 bits in 2C representation.

- ✓  $X = A B \in [-15,15]$  requires 5 bits in 2C.
- ✓  $|X| = |A B| \in [0,15]$  requires 5 bits in 2C. Thus, the second operation  $0 \pm X$  only requires 5 bits.
- If  $x_4 = 1 \rightarrow X < 0 \rightarrow \text{we do } 0 X$ .
- If  $x_4 = 0 \rightarrow X \ge 0 \rightarrow \text{we do } 0 + X$ .
- ✓  $R = |A B| \times 4 \in [0,60]$  requires 7 bits in 2C. Note that the MSB is always 0.



#### ELECTRICAL AND COMPUTER ENGINEERING DEPARTMENT, OAKLAND UNIVERSITY ECE-278: Digital Logic Design

abx

0 0 0

0 0 1

0 1 0

101

1 1 0

1 1 1

0 100

1 1

Using only 2-to-1 MUXs, design a circuit that verifies the • logical operation of an NAND gate. f='1' (LED ON) if the NAND gate does NOT work properly. Assumption: when the NAND gate is not working, it generates 1's instead of 0's and vice versa.

f x<sub>good</sub>

1 1

0 1

1 1

0 1

1 1

0

0 0

1 0

1

ab

x

0

1

00

1

0

b

01

1

0

11

0

1

b

0

а



 $f = xab + \bar{x}\bar{b} + \bar{x}\bar{a}$  $f(a, b, x) = \bar{a}f(0, b, x) + af(1, b, x) = \bar{a}(\bar{x} + \bar{x}\bar{b}) + a(xb + \bar{x}\bar{b}) = \bar{a}g(b, x) + ah(b, x)$  $g(b,x) = \bar{b}g(0,x) + bg(1,x) = \bar{b}(\bar{x}) + b(\bar{x})$  $h(b,x) = \overline{b}h(0,x) + bh(1,x) = \overline{b}(\overline{x}) + b(x)$ Also:  $\bar{x} = \bar{x}(1) + x(0)$ 

а

#### PROBLEM 7 (12 PTS)

 Complete the timing diagram of the following circuit. The VHDL code (tst.vhd) corresponds to the shaded circuit.  $z = z_1 z_0, y = y_3 y_2 y_1 y_0$ 



4